rev12(0, nil) -> 0
rev12(s1(X), nil) -> s1(X)
rev12(X, cons2(Y, L)) -> rev12(Y, L)
rev1(nil) -> nil
rev1(cons2(X, L)) -> cons2(rev12(X, L), rev22(X, L))
rev22(X, nil) -> nil
rev22(X, cons2(Y, L)) -> rev1(cons2(X, rev1(rev22(Y, L))))
↳ QTRS
↳ DependencyPairsProof
rev12(0, nil) -> 0
rev12(s1(X), nil) -> s1(X)
rev12(X, cons2(Y, L)) -> rev12(Y, L)
rev1(nil) -> nil
rev1(cons2(X, L)) -> cons2(rev12(X, L), rev22(X, L))
rev22(X, nil) -> nil
rev22(X, cons2(Y, L)) -> rev1(cons2(X, rev1(rev22(Y, L))))
REV22(X, cons2(Y, L)) -> REV1(cons2(X, rev1(rev22(Y, L))))
REV22(X, cons2(Y, L)) -> REV22(Y, L)
REV1(cons2(X, L)) -> REV22(X, L)
REV1(cons2(X, L)) -> REV12(X, L)
REV22(X, cons2(Y, L)) -> REV1(rev22(Y, L))
REV12(X, cons2(Y, L)) -> REV12(Y, L)
rev12(0, nil) -> 0
rev12(s1(X), nil) -> s1(X)
rev12(X, cons2(Y, L)) -> rev12(Y, L)
rev1(nil) -> nil
rev1(cons2(X, L)) -> cons2(rev12(X, L), rev22(X, L))
rev22(X, nil) -> nil
rev22(X, cons2(Y, L)) -> rev1(cons2(X, rev1(rev22(Y, L))))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
REV22(X, cons2(Y, L)) -> REV1(cons2(X, rev1(rev22(Y, L))))
REV22(X, cons2(Y, L)) -> REV22(Y, L)
REV1(cons2(X, L)) -> REV22(X, L)
REV1(cons2(X, L)) -> REV12(X, L)
REV22(X, cons2(Y, L)) -> REV1(rev22(Y, L))
REV12(X, cons2(Y, L)) -> REV12(Y, L)
rev12(0, nil) -> 0
rev12(s1(X), nil) -> s1(X)
rev12(X, cons2(Y, L)) -> rev12(Y, L)
rev1(nil) -> nil
rev1(cons2(X, L)) -> cons2(rev12(X, L), rev22(X, L))
rev22(X, nil) -> nil
rev22(X, cons2(Y, L)) -> rev1(cons2(X, rev1(rev22(Y, L))))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
REV12(X, cons2(Y, L)) -> REV12(Y, L)
rev12(0, nil) -> 0
rev12(s1(X), nil) -> s1(X)
rev12(X, cons2(Y, L)) -> rev12(Y, L)
rev1(nil) -> nil
rev1(cons2(X, L)) -> cons2(rev12(X, L), rev22(X, L))
rev22(X, nil) -> nil
rev22(X, cons2(Y, L)) -> rev1(cons2(X, rev1(rev22(Y, L))))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
REV12(X, cons2(Y, L)) -> REV12(Y, L)
POL( REV12(x1, x2) ) = x2
POL( cons2(x1, x2) ) = x1 + x2 + 1
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
rev12(0, nil) -> 0
rev12(s1(X), nil) -> s1(X)
rev12(X, cons2(Y, L)) -> rev12(Y, L)
rev1(nil) -> nil
rev1(cons2(X, L)) -> cons2(rev12(X, L), rev22(X, L))
rev22(X, nil) -> nil
rev22(X, cons2(Y, L)) -> rev1(cons2(X, rev1(rev22(Y, L))))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
REV22(X, cons2(Y, L)) -> REV1(cons2(X, rev1(rev22(Y, L))))
REV22(X, cons2(Y, L)) -> REV22(Y, L)
REV1(cons2(X, L)) -> REV22(X, L)
REV22(X, cons2(Y, L)) -> REV1(rev22(Y, L))
rev12(0, nil) -> 0
rev12(s1(X), nil) -> s1(X)
rev12(X, cons2(Y, L)) -> rev12(Y, L)
rev1(nil) -> nil
rev1(cons2(X, L)) -> cons2(rev12(X, L), rev22(X, L))
rev22(X, nil) -> nil
rev22(X, cons2(Y, L)) -> rev1(cons2(X, rev1(rev22(Y, L))))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
REV22(X, cons2(Y, L)) -> REV1(cons2(X, rev1(rev22(Y, L))))
REV22(X, cons2(Y, L)) -> REV22(Y, L)
REV22(X, cons2(Y, L)) -> REV1(rev22(Y, L))
Used ordering: Polynomial Order [17,21] with Interpretation:
REV1(cons2(X, L)) -> REV22(X, L)
POL( rev22(x1, x2) ) = x2
POL( REV22(x1, x2) ) = x2 + 1
POL( rev1(x1) ) = x1
POL( rev12(x1, x2) ) = max{0, x1 - 1}
POL( REV1(x1) ) = x1
POL( 0 ) = max{0, -1}
POL( s1(x1) ) = x1
POL( nil ) = 1
POL( cons2(x1, x2) ) = x2 + 1
rev1(cons2(X, L)) -> cons2(rev12(X, L), rev22(X, L))
rev22(X, nil) -> nil
rev1(nil) -> nil
rev22(X, cons2(Y, L)) -> rev1(cons2(X, rev1(rev22(Y, L))))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ DependencyGraphProof
REV1(cons2(X, L)) -> REV22(X, L)
rev12(0, nil) -> 0
rev12(s1(X), nil) -> s1(X)
rev12(X, cons2(Y, L)) -> rev12(Y, L)
rev1(nil) -> nil
rev1(cons2(X, L)) -> cons2(rev12(X, L), rev22(X, L))
rev22(X, nil) -> nil
rev22(X, cons2(Y, L)) -> rev1(cons2(X, rev1(rev22(Y, L))))